<template>
	<view class="homeLayeout pageBg">
		<custom-nav-bar title="推荐"></custom-nav-bar>
		<!-- banner轮播图 -->
		<view class="banner">
			<swiper indicator-dots indicator-color="rgba(255,255,255,0.3)" indicator-active-color="#fff" autoplay circular>
				<swiper-item v-for="item in 3" :key="item">
					<image src="/common/images/banner1.jpg" mode="aspectFill"></image>
				</swiper-item>
			</swiper>
		</view>
		
		<!-- notice公告 -->		
		<view class="notice">
			<view class="left">
				<uni-icons type="sound-filled" size="20" color="#28b389"></uni-icons>
				<text class="text">公告</text>
			</view>
			<view class="center">
				<swiper vertical autoplay interval="1500" duration="300" circular>
					<swiper-item v-for="item in 4" :key="item">
						<navigator url="/pages/notice/detail">
						文字内容文字内容文字内容文字内容文字内容
						</navigator>
					</swiper-item>
				</swiper>
			</view>
			<view class="right">
				<uni-icons type="right" size="16" color="#333"></uni-icons>
			</view>
		</view>
		
		<!-- select每日推荐 -->
		<view class="select">
			<common-title>
				<template #name>每日推荐</template>
				<template #custom>
					<!-- 每日推荐右边的日期图标 -->
					<view class='data'>
						<view class="text">
							<uni-icons type="calendar" size="18"></uni-icons>
							<uni-dateformat :date="Date.now()" format="dd日"></uni-dateformat>
						</view>
					</view>
				</template>
			</common-title>
			<view class="content">
				<scroll-view scroll-x>
					<view class="box" v-for="item in 8" :key="item" @click="goPreview">
						<image src="/common/images/preview_small.webp" mode="aspectFill"></image>	
					</view>
				</scroll-view>
			</view>
		</view>

		<!-- theme专题精选 -->
		<view class="theme">
			<common-title>
				<template #name>专题精选</template>
				<template #custom>
					<navigator url="" class="more">More+</navigator>
				</template>
			</common-title>
			<view class="content">
				<theme-item v-for="item in 8" :key="item"></theme-item>
				<theme-item isMore="true"></theme-item>
			</view>
		</view>

	</view>
</template>

<script setup>
	const goPreview = () => {
		uni.navigateTo({
			url:"/pages/preview/preview"
		})
	}
</script>

<style lang="scss" scoped>
.homeLayeout {
	// banner部分
	.banner {
		width: 750rpx;
		padding: 30px 0;
		swiper {
			width: 750rpx;
			height: 340rpx;
			// &代表父级 swiper-item 
			&-item {
				padding: 0 30rpx;
				image {
					width: 100%;
					height: 100%;
				}
			}
		}
	}

	// notice部分
	.notice {
		width: 690rpx;
		height: 80rpx;
		background: #f9f9f9;
		margin: 0 auto;
		border-radius: 80rpx;
		display: flex;
		.left {
			width: 140rpx;
			display: flex;
			justify-content: center;
			align-items: center;
			:deep() {
				.uni-icons {
					color: $brand-theme-color !important;
				}
			}
			.text {
				color: $brand-theme-color;
				font-weight: 600;
				font-size: 28rpx;
			}
		}
		.center {
			flex: 1;
			line-height: 80rpx;
			swiper {
				height: 100%;
				&-item {
					height: 100%;
					font-size: 30rpx;
					color: #666;
					overflow: hidden;
					white-space: nowrap;
					text-overflow: ellipsis;
				}
			}
		}
		.right {
			width: 70rpx;
			display: flex;
			justify-content: center;
			align-items: center;
		}
	}

	// select部分
	.select {
		padding-top: 50rpx;

		.data {
			color: $brand-theme-color;
			display: flex;
			align-items: center;
			:deep() {
				.uni-icons {
					color: $brand-theme-color !important;
				}
				}
			.text {
				margin-left: 5rpx;
			}
		}

		.content {
			width: 720rpx;
			margin-left: 30rpx;
			margin-top: 30rpx;

			scroll-view {
				white-space: nowrap;
				width: 100%;
			}

			.box {
				width: 200rpx;
				height: 430rpx;
				display: inline-block;
				margin-right: 15rpx;

				image {
					width: 100%;
					height: 100%;
					border-radius: 12rpx;
				}
			}

			.box:last-child {
				margin-right: 30rpx;
			}
		}
	}

	// theme部分
	.theme {
		padding: 50rpx 0;

		.more {
			font-size: 32rpx;
			color: #888;
		}

		/* 关键修改：限定在 theme 下的 content */
		.content {
			margin-top: 30rpx;
			padding: 0 30rpx;
			display: grid;
			gap: 15rpx;
			grid-template-columns: repeat(3, 1fr);
		}
	}
}
</style>
